package com.canaan.business.domain.inOutStock;

import com.fasterxml.jackson.annotation.JsonFormat;
import com.canaan.common.annotation.Excel;
import com.canaan.common.annotation.TableName;
import com.canaan.common.core.domain.BaseEntity;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;

import java.util.Date;
import java.util.List;

/**
 * 码货任务单对象 wms_yardage_goods_task_order
 *
 * @author ruoyi
 * @date 2023-01-30
 */
@Data
@ApiModel(description = "wms_yardage_goods_task_order")
@TableName("wms_yardage_goods_task_order")
public class YardageGoodsTaskOrder extends BaseEntity {
    private static final long serialVersionUID = 1L;

    /** ID */
    @ApiModelProperty("id")
    private Long id;

    /** 编号 */
    @Excel(name = "编号")
    @ApiModelProperty("编号")
    private String no;

    /** 类型，1生产入库 2退料入库 3报废入库 4退货入库 5待检入库 6收货入库 7调拨入库 8其他入库 */
    @Excel(name = "类型", dictType = "sh_inout_type")
    @ApiModelProperty("类型，1生产入库 2退料入库 3报废入库 4退货入库 5待检入库 6收货入库 7调拨入库 8其他入库")
    private Integer orderType;

    /** 申请状态 1新建 2进行中 */
    @Excel(name = "状态", dictType = "yardage_goods_order_status")
    @ApiModelProperty("状态")
    private Integer orderStatus;

    /** 物料编号 */
    @Excel(name = "物料编号")
    @ApiModelProperty("物料编号")
    private String productNo;

    /** 物料名称 */
    @Excel(name = "物料名称")
    @ApiModelProperty("物料名称")
    private String productName;

    /** 批次号 */
    @Excel(name = "批次号")
    @ApiModelProperty("批次号")
    private String batchNo;

    /** 关联编号 */
    @Excel(name = "关联编号")
    @ApiModelProperty("关联编号")
    private String relOrderNo;

    /** 码货人编号 */
    @ApiModelProperty("码货人编号")
    private String shipper;

    /** 码货员 */
    @ApiModelProperty("码货员")
    private String shipperName;

    /** 仓库编号 */
    @Excel(name = "仓库编号")
    @ApiModelProperty("仓库编号")
    private String storehouseNo;

    /** 库区编号 */
    @Excel(name = "库区编号")
    @ApiModelProperty("库区编号")
    private String storehouseAreaNo;

    /** 仓库名称 */
    @Excel(name = "仓库名称")
    @ApiModelProperty("仓库名称")
    private String storehouseName;

    /** 库位编号 */
    @ApiModelProperty("库位编号")
    private String storehouseLocationNo;

    /** 库位名称 */
    @Excel(name = "库位名称")
    @ApiModelProperty("库位名称")
    private String storehouseLocationName;

    /** 申请数量 */
    @Excel(name = "申请数量")
    @ApiModelProperty("申请数量")
    private Long orderQty;

    /** 实际数量 */
    @Excel(name = "实际数量")
    @ApiModelProperty("实际数量")
    private Long actualQty;

    @Excel(name = "分配数量")
    @ApiModelProperty("分配数量")
    private Long  distributeQty;


    @ApiModelProperty("人库单明细ID")
    private Long  inOrderId;

    /** 区域 */
    @Excel(name = "区域")
    @ApiModelProperty("区域")
    private String area;

    /** 完成时间 */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @Excel(name = "完成时间", width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss")
    private Date completeTime;

    /** 创建人 */
    @ApiModelProperty("创建人")
    private String createBy;

    /** PDA列表显示仓库字段 */
    @ApiModelProperty("PDA列表显示仓库字段")
    private String pdaLocationLabel;

    /** 创建人 */
    @Excel(name = "创建人")
    @ApiModelProperty("创建人名称")
    private String createByName;

    /** 创建时间 */
    @Excel(name = "创建时间", type = Excel.Type.EXPORT, dateFormat = "yyyy-MM-dd HH:mm:ss")
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @ApiModelProperty("创建时间")
    private Date createTime;

    /** 更新人 */
    @ApiModelProperty("更新人")
    private String updateBy;

    /** 更新人 */
    @Excel(name = "更新人")
    @ApiModelProperty("更新人名称")
    private String updateByName;

    /** 更新时间 */
    @Excel(name = "最后更新时间", type = Excel.Type.EXPORT, dateFormat = "yyyy-MM-dd HH:mm:ss")
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @ApiModelProperty("更新时间")
    private Date updateTime;

    /** 排序 */
    @Excel(name = "排序")
    @ApiModelProperty("排序")
    private Integer sort;

    /** 是否删除：1是 0否 */
    @ApiModelProperty("排序")
    private String delFlag;

    @ApiModelProperty(value="多个状态条件，非数据库字段，只用于查询")
    List<String> orderStatusList;
}
